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ABSTRACT 

This paper documents the process by which a data structure for 
a Computer -Aided-Design system was selected and implemented on a 
medium scale computer. Included is a survey of the types of structures 
currently used in C.A.D. applications and a discussion of their capabil- 
ities and resource requirements. 
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I. INTRODUCTION 



The metamorphosis of a computer with graphic input- output 
capability into a general computer-aided design system is dependent 
primarily upon the development of a scheme for modeling the problems 
to be solved. Such a model, or data structure, must be capable of 
both creating the display file for graphical representation of the 
problem, and presenting the application programs with data in a use- 
able form. 

Terms that will be used to discuss data structures are: 

1) Pointer- the machine address of a Data Cell; 

2) Data Item - one or more machine words containing data; 

3) Data Cell - a contiguous block of memory containing 
Data Items; 

4) Low Level Data Structure - a modeling scheme in which the 
mechanisms for construction of the structure are defined by 
the user; 

5) Pre-defined Data Structure - a modeling scheme in which 
the mechanisms for construction of the structurn are 
pre-defined. 

The selection of the data structure to be incorporated within a 
CAD system is at best a complex proces s. No established procedure 
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exists by which firm conclusions can be drawn about the advantages 
and disadvantages of the various modeling schemes available. 

The simplest structure with which to build a problem model is 
one in which the structure is pre-defined (i. e. , a high level structure). 
In the pre-defined structure the data structure language is used to 
describe and manipulate the ordering of cells within a fixed structure. 
The ease of use is achieved by sacrificing flexibility. Not all problems 
can be efficiently modeled by a fixed structure, hence selection of 
such a structure is de facto a decision to reduce the systems capability 
in certain design problem areas. 

Somewhat greater flexibility is provided by the low level data 
structures. In these only the data cells and the method of expressing 
relationships between them are pre-defined. The associated language 
enables the user to build from these cells, using the prescribed 
relational mechanisms, structures of the various forms. [Ref. 1] 

is an example of this type of structuring method. Within limits the 
user is capable of tailoring the structure to more closely meet the 
needs of the problem to be solved. 

On a lower level still are the generalized data structures such 
as AED [Ref. 2] which have the capability to model any problem that 
can be formalized. The power of these modeling schemes arises 
from the ability of the user to define both the data cell and the methods 
for expressing relationships between them. Using a variety of tech- 
niques (i. e. , hash coding, dictionary lookup, stacks, rings, etc.), 
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structures of any type and degree of complexity can be constructed. 

By careful analysis of the design problem, a structure can be built 
which provides an optimized model. When a CAD system is expected 
to be applied to a greatly diverse problem set, the implementation of 
a generalized structure is virtually mandatory. Unfortunately the 
necessity to define the structure and all the relationships within that 
structure before work can progress towards solution of the problem 
places a large additional burden on the system user. 

Computer-aided design systems have, in general, been developed 
on computers with large main memories. The selection of which 
philosophy of structure (pre-defined or generalized) and which specific 
structure within that philosophy to implement on such a computer may 
be based primarily on the nature of the problems to which the system 
is to be applied and the skill of the users. When large amounts of 
main memory are not available, as in the case of medium sized 
computers, then the selection of data structure may be strongly 
influenced by the computer resources available. 

The choice of a structure to be used by a medium sized computer 
should incorporate the best possible trade off between efficiency of 
memory utilization and processor time while placing as few restric- 
tions as possible on the size and complexity of the models to be 
created. 

The purpose of this paper is to document the process by which a 
data structure was selected and implemented on a medium sized 
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computer with intelligent graphic terminals. The particular equip- 
ment involved in the implementation was an XDS-9300 with AGT- 10 
graphic terminals. While many of the specifics of the implementation 
are machine dependent the criteria of selection and general techniques 
of implementation have application to other equipments of similar 
capability. 
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II. SELECTION OF A DATA STRUCTURE 



There exists a variety of data structures which either have been 
developed expressly for use in computer-aided-design systems or lend 
themselves to that application. All, in general, share the property of 
explicitly defined relationships between data items on both a com- 
monality and hierarchical basis. Gray [Ref, 3] noted that additionally 
CAD structures should be capable of dynamic growth and change as 
well as have the ability to be entered at any point within the structure. 
Although the form and mechanisms of such structures vary, most can 
be classified into distinctive groups. 

The first group is that of Set-Theoretic data structures. Childs 
[Ref. 4] has developed a system by which data is stored contiguously 
without pointers. A block of pointers to the data items is created (the 
Beta block) each with a unique integer associated with it. A second 
block (the Eta block) contains sets of integers, each set then defining 
a relationship between data items. Mechanisms for defining sets and 
performing set operations complete the system and provide the capabil- 
ity of defining completely arbitrary relationships in any structure 
desired. Other systems based on set-theory operations have been 
developed and while offering great potential in CAD applications, have 
not achieved wide usage. This is possibly due to the difficulty in 
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implementation of such a system and the relatively early stage of 
development. 

The second grouping of structure schemes contains those based 
on associative memory techniques, of which the LEAP data structure 
by Rovner etnd Feldman [Ref. 5] is perhaps the best example. LEAP 
operates on triples, where the triple is an ordered set of three data 
items- ATTRIBUTE, OBJECT, and VALUE. Retrievals are made on 
the basis of all three data items, any two or any single item. This is 
accomplished by means of three separate structure spaces: Attribute 

space; Object space; and Value space, with a copy of the triple in each 
space. Each triple is stored as a permutation in which the first data 
item corresponds to the name of the structure space. Within each 
structure space the permutation is stored ait an address determined by 
hash-coding two of the three data items. Retrievals of the form 
ATTRIBUTE OF (UNSPECIFIED) IS VALUE can be made by accessing 
the attribute structure space, hashing the attribute and value data 
items together and retrieving the desired information from the result- 
ing address. The Attribute structure space contains two registers 
each "containing" a unique ATTRIBUTE value (e. g. "father 11 ) and a 
pointer to a chain of triples in the structure space with the same 
unique ATTRIBUTE. In this fashion retrievals of the form 
ATTRIBUTE OF (UNSPECIFIED) IS (UNSPECIFIED) maybe made. 

The Object and Value structure spaces contain similar registers. 
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LEAP also contains provision for inserting data items into unordered 
sets, creating rings of items with the same ATTRIBUTES. 

LEAP and similar systems, due to the duplication of storage, 
require large amounts of storage for relatively simple models, but in 
general offer good search efficiency. 

The third general category of data si ructures contains those based 
on the concept of ’’rings 1 '. The large majority of structures which have 
found application in CAD systems are elements of this classification.. 
Included here are the structures developed with a view toward graphic 
applications, such as the rings of Sutherland’s SKETCHPAD [Ref. 6], 
CORAL [Ref. 7], ASSOCIATIVE STRUCTURE PACKAGE (ASP) [Ref. 8], 
etc. , as well as some of the more general list processing structures 
exemplified by SLIP [Ref. 9]. 

Ring structures are characterized by a basic structure consisting 
of a ring start which contains a pointer to the first data cell in the ring. 
Each cell ’'points" to the next, and the last cell "points" back to the 
ring start. Rings may be two-way linked with both forward and back- 
ward pointers. A data cell may be variable in length (i. e. contain 
a variable number of data items) and in general can be a member of 
more than one ring. Hierarchy may be denoted by placing rings on 
rings on rings, etc. 

Ring structures may require less processor time for some 
operations than other structures since the addresses of data cells 
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required for retrieval or structure manipulation operations are 
stored with the data cells rather than computed. The decrease in 
processor time is of course traded off against the increased storage 
requirements . 

In examining the various structure groupings from the pre-defined 
vs. generalized standpoint a few conclusions can be drawn. Set the- 
oretic techniques seem to offer the greatest potential for generalized 
structures. Set theory can be considered a form of '’relational cal- 
culus” and provides a formalized method of defining and operating 
upon relationships. Childs 1 STDS would appear to satisfy all the 
requirements of a generalized structure. Associative memories also 
appear to be fertile ground, particularly in hardware form as opposed 
to software simulated. LEAP, as Hamilton [Ref. 10] points out, also 
contains generalized structural ability. Ring-based structures are as 
a rule of the pre-defined type. 

AED previously described as a generalized structure does not 
fall readily into any of the three groupings, principally because its 
structure is so user defined. 

In the selection process of a data structure for the medium scale 
computer, the first two groups were eliminated from consideration. 
The s et- theoretic structures were discarded primarily due to the 
problem of constructing an ordering scheme for the sets of data items. 
A s et theoretic data structure is dependent upon all sets being well 
ordered and that ordering being preserved under union. If all sets 
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are well ordered then set operations can be accomplished by a merge 
or binary search. Lacking well ordering of sets, the execution of set 
operations becomes inefficient and the system impractical. The user 
of a set theoretic structure must define the well ordering relationships 
of the sets involved. Each set must have a unique linear representation 
which reflects the rank and preserves the order of its elements. The 
construct of a mechanism for such set representations which covers 
the wide range of data items operated upon in a CAD environment is a 
decidedly non- trivial problem. 

Associative memory structures were not seriously considered 
because of their rather excessive storage requirements. The LEAP 
structured speed of operation is relatively independent of structure 
size due in part to its efficient use of secondary storage. LEAP 
appears to offer great potential when dealing with very large problems, 
but on medium- sized computers the storage requirements of assoc- 
iative techniques appear prohibitive. The XDS-9300 at N. P.S. is 
configured with 32K of main memory and approximately 250K avail- 
able to the user on secondary storage. The present monitor system 
provides no random access file capability hence secondary storage 
(drum) is organized sequentially. The already high processor over- 
head of associative techniques coupled with the large additional burden 
of paging in a sequential environment would appear to add strong 
further argument against implementing such a structure on the 9300. 
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AED was not selected for two reasons, A large amount of soft- 
ware is associated with the implementation of AED. This software 
includes the AED Jr. language specifier, the AED Processor, and 
many system packages which provide the mechanisms for manipulating 
the structures defined. This software, which must reside on secondary 
storage in its entirety and in main memory in part (at execution time), 
effectively reduces the storage space available for structures and 
applications programs. This reduction becomes important when main 
memory is small as secondary storage will undoubtedly be required 
for overlay of large applications programs or for paging of large data 
structures. The large software requirements of AED are, of course, 
related directly to its generalized nature. The limited scope of the 
problems expected to be run on the 9300 did not appear to jvxstify a 
generalized system. 

The second reason AED was removed from consideration was the 
difficulty of maintaining an interface between it and application pro- 
grams. As mentioned in the discussion on genereilized structures the 
user is faced with the responsibility of completely defining the data 
structure used to model the problem. Application programs are, in 
a sense, partially defined by the data structure. For each unique 
structure defined by the user a unique application program must be 
written to access that structure. This adds further to the already 
heavy burden this modeling system places on the user. 
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L Q and other low level structures were eliminated from con- 
sideration on the basis that the principle users (engineers) would 
more effectively be able to use the system if they were freed from 
the task of defining the data structure. The choice was thus narrowee 
to the group of ring based structures. The structures in this group 
differed primarily in implementation, and the final selection was 
made on that basis. 

The selection of languages available on the N.P.S. XDS-9300 is 
limited to FORTRAN IV and assembly language. Any implementation 
of a data structure on this machine must be either embedded in 
FORTRAN or implemented in the form of a high level data structure 
language with its associated processor. The latter method requires 
the user to learn a new language in which to define his models. A 
data structure language generally does not have the computational 
power of Fortran, and it would not be able to utilize the existing 
supply of Fortran application programs. Another factor is the prob- 
ability of a data structure language processor requiring more sec- 
ondary storage than the macros or subprograms required to embed a 
data structure in an existing high level language. For these reasons 
a structure compatable with Fortran was considered to offer the best 
utilization of the available resources. 

SLIP developed by J. Weizenbaum is a list processing system 
based on ring structures very similar in concept to the rings of 
SKETCHPAD and CORAL. Weizenbaum refers to the rings as 



14 



"symmetric lists". Although SLIP is language and machine independent 
in concept, Weizenbaum’s original implementation was in Fortran, 
and Ref. 9 describes it in that form. This demonstrable compatability 
with Fortran coupled with the resulting ease of use by 9300 users made 
it a reasonable choice for implementation. 
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III. IMPLEMENTATION OF SLIP 



Some basic definitions must be made in order to clearly describe. 
Weisenbaum's data structure system. The data cell contains two data 
items. The first contains three fields: the ID field; the LNKL (left 

link) field; and the LNKR (right link field. The function of the ID field 
is to provide storage for an integer which acts as a descriptor for the 
data cell utilization. There aTe four utilization codes which are dis- 
cussed below. The LNKL and LNKR fields contain pointers to the 
next left and next right cells respectively in the ring. The second 
data item in the cell can be considered to contain pure data (i. e. 
non- specified) but may be subdivided into fields in the same manner 
as the first data item. Figure 1 illustrates the format of the SLIP 
cell. 

A ring originates with a HEADER cell. This cell carries an ID 
code of 2, the LNKL points to the last (left most from the standpoint 
of the HEADER) cell in the ring and the LNKR points to the first cell 
in the ring (See figure 2). The second data item in the HEADER con- 
tains three fields: the LIST MARK field; the DESCRIPTION LIST 
POINTER; and the REFERENCE COUNTER. The LIST MARK field 
contains a user defined integer code allowing the user to mark lists 
for any desired purpose. The DESCRIPTION LIST POINTER, when 
non-zero points to an attribute list which "describes n the list headed 
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by the HEADER. The REFERENCE COUNTER contains the number 
of lists of which the list headed by the HEADER is a sublist. This 
number is important in the storage management process which is 
described below. 

A HEADER is referenced by its NAME. A NAME is a data item 
in which the ID code is zero and the LNKL and LNKR fields both con- 
tain pointers to the HEADER. A HEADER may have its NAME stored 
in many locations. The designations of these locations are known as 
ALIASES for the NAME of the HEADER. 

The ring structures of SLIP are acc.es sed primarily by means of 
READER cells (See figure 3). A READER has an ID code of 3, the 
LNKL field initially points to the HEADER of the ring the READER 
is to "read and the LNKR field is zero. Should the structure to be 
,f read M contain sub-rings, and it is desired to read the sub-rings, 
then a READER is appointed for each sub- ring as encountered and the 
previous READER is pushed down on a READER stack. The LNKR 
field of the READER cell is used to maintain the chaining of the 
READER stack. The LNKL field of the READER is set to point to the 
next cell to be read after each read operation. The second data item 
of the READER cell contains a zero in the first field, a pointer to the 
HEADER of the ring being read in the second field, and a LEVEL 
COUNTER in the third field. The purpose of the pointer to the 
HEADER (which is not modified as the structure is read) is to enable 
the READER to be re-initialized without having to read the entire ring. 
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The above figures were extracted from Ref. 9 
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The LEVEL COUNTER indicates the number of READER cells pushed 
down on the READER stack (i. e. how far down the current READER 
is in the hierarchy of the structure). 

The SLIP structure is organized around the basic ring which con- 
sists of a HEADER followed by an arbitrary (including zero) number 
of ring cells. A null ring consists of a HEADER whose LNKL and 
LNKR fields point to the HEADER. The ring cells carry on ID code 
of 0 or 1 and the LNKL and LNKR fields chain the ring cells together. 
The second data item in the ring cells (henceforth referred to as a 
DATUM) contains either information or a NAME as indicated by the 
cell ID code. A cell ID of 0 indicates the contents of the DATUM is 
data in user specified form. If the ID is 1, then the DATUM contains 
a NAME (points to a ring HEADER) and indicates that the ring with 
that HEADER is a sub - ring. Note that a ring may be a sub- ring of 
more than one ring and in fact may be a sub- ring of itself. There is 
no limit to the levels of hierarchy that can be defined. 

Since rather elaborate and complex ring structures can be con- 
structed with SLIP, a sophisticated system of access is required. 
Weizenbaum has incorporated into SLIP a scheme by which the 
structures created can be traversed in any order desired. This 
traversal is accomplished by means of the advance functions and 
READER cells. Advances are of two general types- -structural and 
linear. In the structural advances whenever a NAME is encountered 
as a DATUM a new READER is appointed, the old READER stacked, 
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and the advance continued in the sub- ring pointed to by the NAME. 

The linear advance functions do not allow the advance operation to 
ascend or descend in the structure hierarchy. Advances can be made 
either clockwise or counter-clockwise in the ring and with one of 
three termination criteria* Advances are specified to be on the basis 
of Word, NAME, or Element. An element is a data cell not containing 
a NAME, and a Word is the union of the classes NAME and Element. 
HEADER cells are categorized separately and advances for a given 
level of hierarchy terminate on reaching a HEADER cell. The struc- 
tural advance n pops n the READER stack and continues the search on 
the next higher level. If the termination criterion is Word, the linear 
advance operation accesses the next data cell in the ring and returns 
the DATUM of that data cell if that cell is a Word (i. e. not a HEADER). 
Should the DATUM of the cell pointed to by the READER when the 
advance function is called contain a NAME, then the structural 
advance would return the DATUM of the first Data Cell of the ring 
pointed to by the NAME. In the case of a linear advance based on 
NAME, the advance continues cell by cell until a cell with ID code 1 
is reached. At that point the advance halts and the NAME is returned 
as the function value. The structural advance operates in the same 
fashion with the following exception. If the READER is pointing at a 
Data Cell containing a NAME when the advance function is called, then 
the ring pointed to by that NAME is accessed and the first NAME 



encountered there is returned. An entire structure may be traversed 
if a structural advance on the basis of Word is called for and the 
advance is initiated at hierarchy level zero. 

Storage management in SLIP is accomplished by means of main- 
taining a list of available storage (AVSL). The AVSL contains all 
unallocated data cells chained together in a one-way linked list. As 
cells are required they are allocated from the top of the list and when 
cells are deleted from the structure they are returned to the bottom of 
the list. When all references to a ring have been deleted that ring is 
also deleted (permanent rings can be created by the user which will 
not be automatically deleted if desired). This feature is made possible 
by the REFERENCE COUNTER in the ring HEADER. Each time a cell 
is created whose DATUM contains a NAME, the REFERENCE COUNTER 
of the ring HEADER pointed to by the NAME is incremented. When 
that cell is deleted the REFERENCE COUNTER is decremented. 

Should the counter become zero, then the ring is returned to the list 
of available storage. 

SLIP provides the user with a full range of mechanisms for placing 
information on rings and manipulating those rings. Rings may be 
split or merged. Cells may be added or deleted at any point within 
a ring. The contents of any cell may be readily accessed or altered. 

For a full description of these and the other mechanisms of SLIP, 
the attention of the reader is invited to Ref. 9- 
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Weizenbaum’s Fortran implementation of SLIP is comprised of a 
set of Fortran subprograms which are designed to be machine independ- 
ent and a set of primitive assembly language subprograms. These 
highly machine dependent routines provide the interface between SLIP 
and the computer on which it is to be utilized. The primitive routines 
define the data cell, establish and retrieve the contents of the data 
cells and provide the recursive capability required by the Fortran 
subprograms. 

The implementation of SLIP on the XDS -9300 involved primarily 
the creating of the primitive routines. First, however, a decision on 
the size of the data cells was required. On machines with 36 or 48 
bit words, two words per data cell were sufficient. The XDS-9300 
has a word size of 24 bits and requires 15 bits for maximum address - 
ibility. It was decided therefore to allocate four machine words per 
data cell. This provides room for a 3 bit ID field, and two 21 bit 
pointer fields (LNKL and LNKR) in the first two words. The remain- 
ing 3 bit field is unused. The reason for the extra 6 bits per pointer 
is discussed below. The remaining two words comprise the DATUM 
field of the cell. Since two words are required on the 9300 for floating 
point representation, a two word DATUM had the additional benefit of 
allowing the storage of floating point data. 

XDS FORTRAN IV provides the user with the option to intermix 
Fortran and assembly language (XDS SYMBOL) statements. This 
technique was used in writing the primitives. The coding of the 
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branching and parameter passing was left to the Fortran compiler ane 
only those instructions necessarily on the assembly language level 
were so specified. 

One problem peculiar to the 9300 was discovered in the routines 
written by Weizenbaum. Many function and variable names were 
implicitly of integer type. On the majority of machines this would 
cause no difficulty because assignment of values to those functions and 
variables is on the primitive level and hence no type incompatibilities 
or data conversions occur. The XDS-9300 allocates only one word of 
storage for integer type variables, therefore, for example, the NAME 
of a ring could not be returned by a function called LIST. The solution 
to this naming difficulty required that all function and variable names 
which were assigned the values of data items be changed to real valued 
type. Other than this modification little was required in the way of 
changes to the non-primitive routines. 

Once the implmentation was complete and tested, ways to min- 
imize the main memory requirements of resident SLIP routines were 
examined. As implemented on the XDS-9300, SLIP consisted of 102 
subprograms (or approximately thirteen hundred Fortran and SYMBOL 
statements). By placing the SLIP subprograms in the system Primary 
Library only those required by the user’s program will be core res- 
ident at execution time. In most instances a considerable saving of 
memory is achieved over the alternative of making all of the routines 
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resident at execution time. If the user’s program is so constructed 
as to take advantage of the XDS Monitor's overlay package further 
economies in storage can be gained. 

As originally implemented SLIP required the user to define the 
amount of core available to the SLIP structure. Cells were allocated 
from this space and the program terminated when the allocated space 
was exhausted. Only a relatively small percentage of 9300 core is 
required by the resident routines of the Monitor and the AGT-10 inter- 
face leaving the bulk of the 32K main memory available to the user. 

It would require a large user program and model to exhaust the 
remaining core, particularly in view of the excellent system overlay 
features . 

Anticipating the future development of software packages to further 
support the use of the 9300 as n CAD system, it was decided that an 
overlay capability for the SLIP structure would be advantageous. 

This overlay (or paging) of the SLIP structure would offer a present 
benefit of allowing the building of very large models should the need 
arise. 

SLIP was found to lend itself readily to paging. Since originally 
SLIP was restricted to a fixed sized structure space with an available 
storage list for that space, it was a logical extension to conceptualize 
that structure space as one of an arbitrary number of pages, each 
with its unique available storage list. It was desired to maintain the 
pages on the system drum in a random access file. Unfortunately the 
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the random access Monitor routines have only recently been made 
available by XDS Corporation and have not yet been received. The 
use of sequential files was the only alternative and so the pages were 
stored on the drum in that manner. 

The use of sequential files for paging has some rather serious 
disadvantages. Two sequential files must be maintained because 
when a page swap occurs the page presently in core must be re-written 
into the file if it has been modified. Sequential files as a rule must be 
rewritten in their entirety, hence each time a page is paged out all the 
pages in the file must be copied back into the file. This requires the 
standard n 01d Master-New Master” file scheme. In this method each 
time an update to the file is required, the pages are read from the 
n 01d Master” and copied onto the "New Master” until the page to be 
updated is reached. The update is then made from core, and the "Old 
Master” advanced one record. The remainder of the "New Master” 
is written as before. In the next update operation the "New Master” 
becomes the "Old Master” and the process is repeated. This is 
obviously not the most efficient usage of a random access device. 

Sequential file operations on the 9300 are device independent so 
that paging can be done alternatively on magnetic tape merely by 
changing a control card. In some circumstances it might be 
advantageous to have, in effect, permanent storage of the model 
rather than re-creating it each time it is required. 
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Paging was incorporated into SLIP by taking advantage of the 
ease in which major changes in SLIP may be accomplished by modifi- 
cation of the primitive routines. The LNKL and LNKR fields v/ere 
increased to accommodate an additional high order 6 bits. These bits 
indicate the page number of the page which contains the data cell 
specified by the low order 15 bits. Each pointer then still references 
a unique address. 

All retrievals of data items from cells are done by two primitive 
functions. These primitives were modified to incorporate a check for 
residency of the page containing the cell to be accessed. Should the 
page not be resident, page swapping is initiated. In a similar fashion, 
the primitives which store data items in cells were modified to call in 
the appropriate page as needed. 

New pages are created by the non-primitive function which al- 
locates data cells. Originally when the available storage list was 
emptied the program was terminated. In the paged form of SLIP when 
the current page becomes filled this function checks the other existing 
pages for available space. The search begins with the first page 
created and allocates the required cell from the first non-filled page. 
The search is simplified by the fact that the HEADER of the available 
storage list of each page is resident in core. Should all pages be 
filled a new page is careated and the cell allocation made. 

SLIP’s storage management mechanisms were maintained in the 
paged version with little modification. As cells of a page are allocated 
or freed the available storage list for that page is updated. 
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Initially SLIP in its paged form was found to function very in- 
efficiently. Once structures were constructed which exceeded one 
page in size the overhead associated with even the most basic of SLIP 
operations became totally unacceptable. Analysis of the problem 
revealed the source of the inefficiency . 

As rings are constructed each new cell is inserted as a rule either 
to the immediate right or left of the HEADER. The insertion operation 
then requires that either the LNKR or the LNKL of the HEADER be 
modified to point to the new cell. Therefore once the ring is carried 
over onto a new page, each insertion thereafter requires a paging 
operation to access the HEADER followed by a paging operation to 
make the insertion. 

A similar situation arises when retrieving information from SLIP 
structures. As previously discussed, a READER cell is required to 
advance through the structure. If the READER cell was allocated on 
a page different from the one containing the ring which is to be n read n 
the following sequence occurs. The READER is accessed to obtain 
the pointer to the cell to be "read". The appropriate page is swapped 
in and the retrieval made. The page containing the READER is swap- 
ped back in and the pointer to the next cell to be ’’read" is updated. 

It was apparent that the root of the problem was located in the 
requirement that a ring HEADER or a READER cell be accessed for 
virtually every SLIP operation. Should the ring extend over several 
pages or the READER be on a separate page from the ring it was to 
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access, then the number of paging operations required became prohib- 
itively large. A very significant contributing factor was the high 
overhead associated with each paging operation, due to the sequential 
page files. Little could be done to reduce the overhead of the paging 
operation, so the paging scheme had to be improved. 

If the HEADER and READER cells were permanently core resident, 
an order of magnitude reduction in the number of paging operations 
required to process a typical SLIP structure could be achieved. The 
desired residency of these cells was accomplished by the creation of 
page zero. Heretofore pages had been numbered starting with one 
and were all overlayable with only one page resident at a time. By 
flightly modifying existing routines, a page zero was defined which 
remained resident at all times. All HEADER and READER cells are 
allocated from this page. Should page zero become filled, further 
allocations will be made from the next available page and a warning 
given to the SLIP user that paging efficiency has been seriously 
degraded. 

The page zero modification achieved a marked improvement in 
the operation of SLIP in a paged environment. Test programs ex- 
ercising a general mix of SLIP functions demonstrated a reasonable 
degree of efficiency. As in most paging schemes, "worst case" 
situations will result in an excessive amount of computer time being 
devoted to I/O associated with page swapping. Two SLIP subprograms 
RLSTEQL and RLSSCPY are involved in the "worst cases" of the 
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paging scheme. RLSTEQL examines two ring structures for equality 
while RLSSCPY creates a copy of a ring structure. Should the page 
where the second structure resides in the case of RLSTEQL, or on 
which the copy is being constructed in the case of RLSSCOPY, be 
different from the page containing the first structure then excessive 
paging results. A paging operation is then required for each data cell 
of each structure. The programmer will probably have little call to 
use these two functions but if they should be required care should be 
taken to avoid, if possible, having the two structures on separate 
pages. Further reductions in the overhead of paging can undoubtedly 
be made by increasing the efficiency of the paging algorithms, but the 
greatest improvement will be achieved by converting the page files 
from sequential to random acces s . The conversion is discussed in 
the following section. 

Reference 9 provides a reasonably detailed description of the 
important SLIP subprograms. Those subprograms which were 
modified to support the paging scheme and those added for that purpose 
are discussed below in order to complete the documentation. 

INITAS, a non-primitive subroutine which established the public 
lists [Ref. 9] and originally initialized the structure space and the 
available storage list, was modified to create page zero. The initial- 
ization of the structure space and available storage list was delegated 
to a new subroutine named INITIAL. This routine is called each time 
a new page is created. 
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NUCELL, a non-primitive function which does all data cell alloca- 



tion, was modified to initiage paging when the current page becomes 
filled. This function originally was called with a dummy argument to 
satisfy Fortran conventions. NUCELL is now called with an actual 
parameter which causes allocation from page zero if the cell required 
is to be used as a HEADER or a READER.. 

RCELL, a non-primitive function which returns freed cells to the 
available storage list, was modified so as to return the cell to the 
available storage list of the appropriate page. 

NPAGECK is a new primitive function which is called with a 
pointer as an argument. This function examines the high order 6 bits 
of the pointer and compares the page number with the number of the 
current page. If they are not equal a page swap is initiated. NPAGECK 
returns the value of the low order 15 bits (i. e. the ,, local M address 
within the page). 

PAGING is a new non-primitive subroutine which is called with a 
page number as an argument. If the page number is that of an existing 
page the subroutine OLDPAGE is called. Otherwise a call is made to 
the subroutine NEWPAGE. 

OLDPAGE is a new non-primitive called with a page number as 
an argument which initiates an update of the page file (pages out the 
current page) and reads in the page specified. 

NEWPAGE is a new non-primitive called with a page number as an 
argument which initiates an update of the page file and creates a new 
page in core. 
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UPDATE is a new non-primitive subroutine which performs the 
update operation on the page files. This routine initiates a copy of 
the ’’Old Master 11 onto the "New Master" until the current page is 
reached. At this point the current page is copied onto the "New 
Master" and the copy from the "Old Master" continued until the end 
of file. 

COPY is a new non-primitive subprogram which performs the 
copy operation specified by UPDATE. 

The paged implementation of SLIP no longer requires the user to 
specify the size of the structure space. The user is required to de- 
clare on the control card prior to the execution of his Fortran program 
the devices to which the files "Old Master" and "New Master" are to 
be assigned. These files have the logical device numbers of 1 and 2 
respectively. The XDS REAL TIME MONITOR manual specifies how 
assignments of logical device codes to physical devices may be made. 
Additionally the user must include in his Fortran program a CALL 
INITAS statement (without arguments) prior to a call to any other 
SLIP subprograms. Satisfaction of the above two requirements 
provides the user with the full range of SLIP operations with little 
practical restriction on the size of the models he can construct. 
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IV. CONCLUSION 



Several aspects of SLIP as implemented on the XDS-9300 are 
subject to pos sible modification. The size of pages are rather 
arbitrarily set at 250 data cells per page. How appropriate this page 
size will be as SLIP is used to construct the models for a wide range 
of problems is yet to be determined. A study is needed to determine 
the amount of storage required by the average model and how paging 
overhead varies with page size. The results of such a study would 
enable a page size to be established which provided the best opera- 
tional efficiency for the average model. An alternative would be to 
modify SLIP so as to allow the user to specify the page size for his 
specific application. 

Incorporation of the Monitor update which will provide the capabil- 
ity for random access files on the 9300 will greatly reduce paging 
overhead. The sequential page files of the current implementation 
require a READ and a WRITE for each page in the file when a page is 
paged out. Each page in the file is then read until the page to be paged 
in is reached. Conversion to a random access page file would require 
only a single WRITE for the page out operation and a single READ for 
the page in operation. Additionally the duplication of files would be 
eliminated. 
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The conversion of SLIP to accommodate a random access page 
file can be accomplished in a straight forward manner. The sub- 
routines COPY and UPDATE will no longer be needed and can be 
discarded. Subroutines NEWPAGE and OLDPAGE will require 
modification. Modifications to NEWPAGE consist of removing the 
coding which accomplishes the sequential page file operations and 
replacing it with a single RAD Fortran WRITE statement (see the 
XDS FORTRAN IV manual) to write the current page in the file. In 
similar fashion OLDPAGE is modified to random access WRITE the 
current page and READ the page to be swapped in. 

A major modification to SLIP which would increase the storage 
utilization efficiency of SLIP would be the construction of varying 
length data cells. These cells which could contain an arbitrary 
number of data items would be useful for the storage of blocks of 
related data. For example the co-ordinates of the points required 
for the display of an electronic component could be displayed in a 
single data cell rather than as a ring of data cells each containing a 
single set of co-ordinates. The use of variable length data cells, 
however, greatly increases the complexity of the storage management 
s cheme. 

SLIP, as implemented, appears to provide a modeling capability 
of sufficient flexibility to cope with the problems expected to be run 
on the XDS-9300. No practical limitation is placed on the size of the 
models which can be constructed and adequate main memory is 
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available for large resident application programs. Efficiency of the 
sequential file paging scheme is reasonable except in a few situations 
previously described which can be avoided with foresight. A random 
file paging scheme should have good efficiency under all circumstances. 
The SLIP user is not required to learn a new language, and once the 
user gains familiarity with the functions of the SLIP routines he can 
easily incorporate the SLIP structure into existing programs. 

The process by which a specific data structure was selected and . 
implemented at a particular installation lias been described. The 
factors behind the decisions made during the course of that project 
were highly machine and user dependent. A similar project at another 
installation might easily result in the implementation of a modeling 
scheme greatly different from the one implemented at N.P.S. Re- 
gardless of installation, the selection of a data structure for any 
medium sized computer must involve a determination of what capabil- 
ities are expected of the structure selected, as well as an analysis of 
the structures available and the requirements each places on user and 
machine. Finally a compromise must be made axmong structure 
capability, ease of use and machine resources required. 
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STRINDtCL'ULR) 



FUNCTISN ADVLNL(LRzM) 

PR I NT 999 

FORMAT (SH ADVLML ) 

N= ADVLL ( LR/ 1> 1 > 

If (M ) 1/2/1 
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IF ( ID(CAND)-K)5/4j5 
A D V L R = C • 0 



ADVL3 = “1*0 

CALL STRIND(CLEiLR) 

RETURN! 

END 
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IF (N)l,2,l 
'\DVSEL = RFED(LR) 
RETURN 



ADVSE^(LRzM) 
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PRINT 999 
999 F9RV,AT(8H 



N=ADVSL(LR/ 1/0) 
IT (M) 1/2/ 1 
ADVSWL=REED (LR ) 

return 

END 
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FtACT I CN ANEa'VAL ( AT/ VAL/ LST ) 
PRINT 999 

999 F 9R4AT ( 8H ANEWVAL ) 
M =MA9ATK(AT/LST) 
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UNCTION CLIST(X) 
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'-•'.ACTION DELETE(K) 
PRINT 599 

959 FORMAT (8H DELETE ) 
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FUNCTION EQUAL (X/Y) 
PRINT 999 

999 FORMAT (8H EQUAL ) 
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CALL STk'DIR(3TRDIR(STRDIR(C»0jX( I ) ),M J) ), ',<{ J+l ) ) 

call set3IR(0^a38V(w( J) ) # xadgvi a ( j> >,x( i ) ) 

CALL SLTDIR(2>MAD0V(W(J) ) / X ADGV ( W { J 5 ) t X ( J ) ) 

CALL 5ETUIR("1/-1/4095^W(J+1 ) ) 
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FUNCTION IRALST(P) 
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PUNCTI5N LCNTRCO 
PRINT 995 



FPR4AT ( 8H LC\'TR ) 
LC\TR = LNKR ( CSN'T ( K + 2 ) ) 
R E T U R 



00 

•v 

-3* 

«s 

oo 



3 



z 

G3 

CJ 

rr 

v 

z 

3 



cr, 

(A 

CA 

X 



C\ 

* 

LJ 



a 

z 

Cl 

o 

■ — • «v 

a — 

— a 3 

a x — 

X H I — 

a u: x 

CO -< 0TJ> 



— 3 U 

3 — 





O' 


X 


— 


-J 






x~~ * 






X 


CA 


ao a. 


< 


s~y 




t 






CJ 


CA 


— 


— 


3 


If 




If 






* — * 




a 


a 


C 3 ! 


r- 


Z 


a 


z 




1 — 


1 — 


< 


C J 


LJ 


X 


rr 


X 


rr 




C_9 


/ 


X 


o 




*— 


3 


a 


3 




X 


1- « 


a* 


i 




CO 


a 


CO 


a 


o 


3 


rv 


CJ 


1! 


a 


« — » 


LJ 


» — t 


Li-J 


z 




a 


a 


3 


i — i 


_J 


rr 


3 


Ci: 


LJ 



Oi ~r pi 

o\ 

o^ 



X X 

























* — i 
















> c 






— 




3 
















rr 


3 




V 




a 








a 




V 


X 




V 




a 








X 




z 


z 




3 




a 








z 




3 


3 








a 








3 








CA 


x 




a 












a. 


z 


C\ 


00 




a 




3 




Z 


Ch 


oC 


CJ 


O^i 






a 




V 




CJ 


C\ 


— 


h— < 




a 




o 


1 — 1 


z 


z 


*-~t 




a 


r 




< 




ii 


J* 


3 


rr 


1 — 


a 


<: 


u 


z 


A 










3 


CJ 


z 


X 


z 


f- -« 


n 




< 


(Y 


<r 


a o 


/ 


»— < 


rr 


: > 


nx 


CJ 


ij 


o 


a 


a 


U.i X 


3 


rr 


CD 


a 


rr 


a 


A 


3 


LJ 


c/> 


tr lj 


a. 


a 


a 






CA 
















CA 






Ch 
















0\ 






Ch 
















0^ 




X 


X 




CO 


CO 


(.0 






X 


X 



♦— f i; 

v— < CTO <t 

»* a o 
x x 3 



GO co 



49 



07777777 



o 

2 : 

3 

cr> 

a 



CD 

c n 






3 

CO 

O 

X 

<c 

cr 

uj ~ 

a 

0 * 

2 : o 

<1 I.! 

a 

CO < 

< 2 : 

r — < 

O 2 
tiJ cr 

rr ui 



3 

o x 

LU 3 
rr 



_ f 

3 
a 
a 

Lxl 

rr 
1 — co 

CO LlI 



w; 

C 

3 

















4 — 1 








•— » 


(X 




— 






















*v 








3 






' — ■ 






















OJ 










IT) 


— 


X 


3 




















s 








< 


< 


V 


V_^ 






a 
















tH 








T 




— rr 


a 


1 — 




X 














a 










-J 




a a 


X 


X 














a 




t ) 










0> 


y 


a x 


cj 


►— « 




CD 










u 




OJ 












< 


3 a 


CJ 


CD 




a 










no 




3 










•»— * 


cr 


Cl 3 




a. 




3 










_j 






a 








X 


cb 


3 


3 


3 
















cr\ 


X 


CO 








4 — ! 


CD 


OA X 


V 




0 . 


X 




til 






x 


C\ 


XJ 


a 






0 




a 


t 7 o\ co 


3 


X 


a 


v/0 




V 






CT) 


O'. 




>_ 






O'. 




a 


C) O'* — 


3 


C* 


to 






X 


X 








a 


c 


V 


/ 




a 






ti X 


t — * 




H— 


* 


3 


rr 




1— 


a 


< 


X 


II 


rr 


a 


< 


ai 


a a < 


a a 


a 


a 


c 






3 




CJ 


X 


> 


— 


a 


— > 


X 


a. y 


X 


u x y 


a 3 


0 




r 


tX 


< 


1 


0 


2* 


t— * 


rr 




a) 


a 


►-4 


c i cr 


a 0 


2" — fr 


x a 0 


X 


•—< 


cr *-* 


1 — 


h— 


1x3 


/_ 


3 


cr 


3 


a 


aO 


a 


a- 


h- CD 


T 
X . 


3 rr c ? 


0 . a x 


3 


a 


CD H 


at 


10 


nr: 


111 


lx 


a 


a 


»— H 


3 0 


a 


co a 


i a 


a a a 


3 a m 


a 


Q. 


a 2 


















































CO 




OJ 




4~< 


* — I 




3 








3 














3, 










0 




3 








a 














O'k 










0\ 




O' 








o^. 


CO 


CO 








X 


X 














X 

X 






X 


X 



(0 CO ( 



^ CO 



50 



CTR * L 

SHIRT 025011 
SHIFT 021011 



CO 

f— co in 











c/) 
















*N 


















. — 


















3 














O' 


ro 


















V 






















UJ 












— 






















a _ 














UJ 




to 










Pi 










*-H 










CL 




3 




rsJ 










CO 




rr 










— 








— 


-f 










3 




tr 




— 










rr 




3 






. — . 




- — . 






* — . 


J 


UJ 










rr 




n 




3 










70 




a. 


f — 




3 




X 


X 




”0 


— 


CD 




— 






o 




rr 




3 










a 




3 


to 




«v 


H 


■ — 


— 






UJ 


rr 




cr 






cr 




3 




lii 










i 






. \ 




V 




r- 


CD 




V 


r- 


3 




o 






j 








CJ 












(Ta 


T 








cu 


cn 


or 


V 


— 


U! 


a 




tr 








O'. 


3 




3 




>0 








0\ 


3C 




o 


rr 


% 


h- 


a_ 


— 


or 


3 


3 




< 






X 


00 


uO 




X 




It 






CO 


C'. 




C) 


if 


:< 


<— 1 


V 


i— 


tr 


X 


UJ 


ii 


O 


tr 






o 


<T\ 


— 




li 




h~ 


7 




► — < 




h- 


ry 


u*. 


to 




< 


to 


r- 


i 


n 


UJ 






X 




» — < 




b- 




a 


x 


x 






3 


K- 


< 


O 


o 


> 


“0 


X 


j 


X 


> 




CD 


<17 




rr 




h~ 


K- 






t j 




>— < 






CJ 


X 


X 


or 


nr 








— 


a. 


a 


_j 


or 


u- 


3 


~D 




3 


X 


^7 


tr 


cr 


< 


CL. 


h- 


o 


s 


• — i 


rr 


3 


: j 


< 








_j 


< 


3 


_D 




3 


h~ 


n 


X 


» — ; 


tr 


v — f 


o 




Q_ 


u 


j/ 


3 


tr 


CD 




Cl 


It 


Ll 


Ll 


U. 


it 


II 


< 


O 


CJ* 


< 


UJ 


X 


3 


tr 


<D 


II 


tr 


CO 


3 


rr 


UJ 


Ll 


tr 


u. 


x 


_J 


X 


*■- 


i — i 


> — ♦ 


3 


X 


CJ 


3 


CD 


UJ 


tr 


3 


3 


CL 


Ll 


IX 


3 














00 






ro 


sO 


*— < 




in 










CU 










0 0 


















go 


































a> 


















CO 


































oo 






to 










X 


X 
































X 


X 







5 1 



NEWR = Lf?DRCP 

N9W-K 

CALL STR IND ( C6MT ( NSW 5 , N’EWR ) 
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LR = LNKR(Ce v JT( A) ) 

CALL SET I NIC ( - 1 / IRi-l,LR 
CALL SETINJD(-1/-1/ IR,A> 
CALL SCTIND(0/A/LR/ IR) 
IF (NAPTST(M) )1,2, 1 



CALL SET I MO ( 1 / - 1 / - 1 * I R ) 

CALL SETI\0(-l/-l/LCNTR( y i) + l/M + 2) 
CALL SIR I NO ( M* I R + 2 ) 

RETURN 

END 
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99? FORMAT (8H FEED ) 

REED = CCM(LM<L(C5NT(i<) )+2) 

RETURN 

END 
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PRIM 999 
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FUNCTION! R V ADNRT (P/N) 
PRINT SS9 

FORMAT (3H FNADNBT) 
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■XTISN R V/ R'<LST ( V /RLST ) 



r 8R MAT ( 8H RMRKLST ) 
rmrklst-rlst 

CALL SETIND(M/-1, - liL3C.T(RLST)+2) 
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CALL SET I NR* 2>LN'<R*L73 P * RNJLS7L 5 
CALL SET I NO ( -1>-1 / RNULSTL'uNKP ) 
CALL SET INC ( -1 / RMULSTL* -1* i_T2P ) 
RETURN 
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FUNCTION SEQRDRdS 
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